<script setup lang="ts">
import XEUtils from "xe-utils";
import Config from "./config.vue";
import { useI18n } from "vue-i18n";
import { clone } from "@pureadmin/utils";
import { reactive, ref, unref, nextTick } from "vue";
import { useCopyToClipboard } from "@pureadmin/utils";
import { useRenderIcon } from "@/components/ReIcon/src/hooks";
import {
  VXETable,
  type TablePublicMethods,
  type VxeTableInstance,
  type VxeFormPropTypes,
  type VxeTableEvents,
  type FormMethods
} from "vxe-table";
import Delete from "@iconify-icons/ep/delete";
import EditPen from "@iconify-icons/ep/edit-pen";

type onEditNRow = {
  name: string;
  model: string;
};

defineOptions({
  name: "Dict"
});

const { t } = useI18n();

const dictData = reactive({
  submitLoading: false,
  showEdit: false,
  selectRow: null,
  filterName: "",
  tableData: [
    {
      id: 1,
      name: "状态",
      model: "",
      children: [
        {
          id: "1-1",
          name: "服务状态",
          model: "serviceStatus"
        },
        {
          id: "1-2",
          name: "在线状态",
          model: "onlienStatus"
        }
      ]
    },
    { id: 2, name: "操作系统", model: "operatingSystem" }
  ],
  formData: {
    name: "",
    model: ""
  },
  formItems: [
    {
      field: "name",
      title: "字典名称",
      span: 24,
      itemRender: {
        name: "$input",
        props: { placeholder: "请输入字典名称" }
      }
    },
    {
      field: "model",
      title: "字典类型",
      span: 24,
      itemRender: {
        name: "$input",
        props: {
          placeholder: "请输入字典类型",
          //这里vxe-table文档并没有提到，可以配置所选组件的所有属性，比如这里可以配置关于vxe-input的所有属性
          disabled: true
        }
      }
    },
    {
      align: "right",
      span: 24,
      itemRender: {
        name: "$buttons",
        children: [
          { props: { type: "submit", content: "提交", status: "primary" } },
          { props: { type: "reset", content: "重置" } }
        ]
      }
    }
  ] as VxeFormPropTypes.Items
});

const originData = clone(dictData.tableData, true);

const xTree = ref<TablePublicMethods>();
const xForm = ref<FormMethods>();

const handleSearch = () => {
  const filterName = XEUtils.toValueString(dictData.filterName).trim();

  if (filterName) {
    const options = { children: "children" };
    const searchProps = ["name"];

    dictData.tableData = XEUtils.searchTree(
      originData,
      item =>
        searchProps.some(
          key => XEUtils.toValueString(item[key]).indexOf(filterName) > -1
        ),
      options
    );

    // 搜索之后默认展开所有子节点
    nextTick(() => {
      const $table = xTree.value;
      $table.setAllTreeExpand(true);
    });
  } else {
    dictData.tableData = originData;
  }
};

// 创建一个防防抖函数，调用频率间隔 100 毫秒
const searchEvent = XEUtils.debounce(
  function () {
    handleSearch();
  },
  100,
  { leading: false, trailing: true }
);

const confirmEvent = async () => {
  const type = await VXETable.modal.confirm("您确定要删除吗？");
  (await type) === "confirm" &&
    VXETable.modal.message({
      content: "测试数据，不可删除",
      status: "error"
    });
};

function commonFn(value, disabled) {
  dictData.selectRow = value;
  dictData.showEdit = true;
  dictData.formItems[1].itemRender.props.disabled = disabled;
}

// 新增
function onAdd() {
  commonFn(null, false);
}

// 新增子类型
function onAddChild(row?: object) {
  console.log("onAddChild", row);
  commonFn(null, false);
}

// 编辑
function onEdit(row?: onEditNRow) {
  dictData.formData = {
    name: row.name,
    model: row.model ? row.model : "暂无字典类型"
  };
  commonFn(row, true);
  // VXETable.modal.message({
  //   content: "测试数据，不可编辑",
  //   status: "error"
  // });
}

// 拷贝当前列表项的数据（字典类型）
const { clipboardValue } = useCopyToClipboard();
const cellDBLClickEvent: VxeTableEvents.CellDblclick = ({ row }) => {
  clipboardValue.value = unref(row).model;
};

const xTable = ref({} as VxeTableInstance);

const submitEvent = () => {
  dictData.submitLoading = true;
  setTimeout(() => {
    const $table = xTable.value;
    dictData.submitLoading = false;
    dictData.showEdit = false;
    if (dictData.selectRow) {
      VXETable.modal.message({ content: "保存成功", status: "success" });
      Object.assign(dictData.selectRow, dictData.formData);
    } else {
      VXETable.modal.message({ content: "新增成功", status: "success" });
      $table.insert(dictData.formData);
    }
  }, 500);
};

const drawer = ref(false);

function onDeploy(value?: object) {
  console.log("onDeploy", value);
  drawer.value = true;
}

function handleClose() {
  drawer.value = false;
}

function onExpand() {
  xTree.value.setAllTreeExpand(true);
}

function onUnExpand() {
  xTree.value.clearTreeExpand();
}

function onHide() {
  xForm.value.reset();
}
</script>

<template>
  <div>
    <!-- 工具栏 -->
    <vxe-toolbar class="bg-bg_color">
      <template #buttons>
        <div class="ml-[20px]">
          <label class="dark:text-text_color_regular">字典名称： </label>
          <el-input
            class="!w-[200px]"
            v-model="dictData.filterName"
            :placeholder="t('buttons.hssearch')"
            @keyup.prevent="searchEvent"
            @input="searchEvent"
            clearable
          />
        </div>
      </template>
      <template #tools>
        <el-button-group>
          <el-button
            type="primary"
            :icon="useRenderIcon('fa:plus-square-o')"
            @click="onAdd"
          >
            {{ t("buttons.hsadd") }}
          </el-button>
          <el-button
            type="primary"
            :icon="useRenderIcon('fa:folder-open-o')"
            @click="onExpand"
          >
            {{ t("buttons.hsexpendAll") }}
          </el-button>
          <el-button
            type="primary"
            :icon="useRenderIcon('fa:folder-o')"
            @click="onUnExpand"
          >
            {{ t("buttons.hscollapseAll") }}
          </el-button>
        </el-button-group>
      </template>
    </vxe-toolbar>

    <!-- 列表 -->
    <vxe-table
      ref="xTree"
      border
      resizable
      :tree-config="{
        children: 'children',
        iconOpen: 'fa fa-minus-square-o',
        iconClose: 'fa fa-plus-square-o'
      }"
      :data="dictData.tableData"
      @cell-dblclick="cellDBLClickEvent"
    >
      <vxe-table-column tree-node field="name" title="字典名称" />
      <vxe-table-column title="字典类型">
        <template #default="{ row }">
          <el-tooltip
            effect="dark"
            :content="'双击复制：' + row.model"
            placement="right"
          >
            <span class="text-model">{{ row.model }}</span>
          </el-tooltip>
        </template>
      </vxe-table-column>
      <vxe-table-column title="操作" width="360" fixed="right">
        <template #default="{ row }">
          <el-button
            link
            type="primary"
            :icon="useRenderIcon(EditPen)"
            @click="onEdit(row)"
          >
            编辑
          </el-button>
          <el-button
            link
            type="primary"
            :icon="useRenderIcon('fa:plus-square-o')"
            @click="onAddChild(row)"
          >
            新增子类型
          </el-button>
          <el-button
            v-show="row.model"
            link
            type="primary"
            :icon="useRenderIcon('fa:cog')"
            @click="onDeploy(row)"
          >
            字典配置
          </el-button>
          <el-button
            link
            type="primary"
            :icon="useRenderIcon(Delete)"
            @click="confirmEvent"
          >
            删除
          </el-button>
        </template>
      </vxe-table-column>
    </vxe-table>

    <!-- 修改、添加弹框 -->
    <vxe-modal
      resize
      width="450"
      v-model="dictData.showEdit"
      :title="dictData.selectRow ? '编辑' : '新增'"
      :loading="dictData.submitLoading"
      @hide="onHide"
    >
      <template #default>
        <vxe-form
          ref="xForm"
          :data="dictData.formData"
          :items="dictData.formItems"
          title-align="right"
          title-width="100"
          @submit="submitEvent"
        />
      </template>
    </vxe-modal>

    <Config :drawer="drawer" drawTitle="字典列表" @handleClose="handleClose" />
  </div>
</template>

<style lang="scss" scoped>
.vxe-input + .vxe-button,
.vxe-input + .vxe-button--dropdown,
.vxe-button + .vxe-button,
.vxe-button + .vxe-button--dropdown {
  margin-left: 0;
}

.vxe-button.type--button:not(.is--round) {
  border-radius: 0;
}

.vxe-toolbar.size--medium {
  padding: 10px;
}

.vxe-table--render-default.size--medium {
  margin-top: 12px;
}

.vxe-button.size--medium.type--button {
  margin-right: 0.07em;
}

.text-model {
  &:hover {
    cursor: pointer;
  }
}
</style>
